import React, { useCallback } from 'react'

type MoreProps = {
  count: number
  onClick?: () => void
}

const More = ({ count, onClick }: MoreProps) => {
  const formatNumber = (num: number) => {
    if (num === 0)
      return '0'
    if (num < 1000)
      return num.toString()
    if (num < 1000000)
      return `${(num / 1000).toFixed(1)}k`
    return `${(num / 1000000).toFixed(1)}M`
  }

  const handleClick = useCallback((e: React.MouseEvent<HTMLDivElement>) => {
    e.stopPropagation()
    e.preventDefault()
    onClick?.()
  }, [onClick])

  return (
    <div className='relative size-8 cursor-pointer p-[0.5px]' onClick={handleClick}>
      <div className='relative z-10 size-full rounded-md border-[1.5px] border-components-panel-bg bg-divider-regular'>
        <div className='flex size-full items-center justify-center'>
          <span className='system-xs-regular text-text-tertiary'>
            {`+${formatNumber(count)}`}
          </span>
        </div>
      </div>
      <div className='absolute -right-0.5 top-1 z-0 h-6 w-1 rounded-r-md bg-divider-regular' />
    </div>
  )
}

export default React.memo(More)
